<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>学生管理系统</title>
    <link rel="stylesheet" href="element-ui/lib/theme-chalk/index.css">
    <script src="js/vue.js"></script>
    <script src="element-ui/lib/index.js"></script>
    <script src="js/axios-0.18.0.js"></script>
</head>
<body>
<div id="div">
    <b style="color: red; font-size: 20px;">学生列表</b>
    <div style="float: right;">
        <el-button type="primary" @click="showAddStu">添加学生</el-button>
    </div>
    <el-table :data="tableData">
        <el-table-column prop="number" label="学号" width="120">
        </el-table-column>
        <el-table-column prop="name" label="姓名" width="120">
        </el-table-column>
        <el-table-column prop="birthday" label="生日" width="140">
        </el-table-column>
        <el-table-column prop="address" label="地址">
        </el-table-column>
        <el-table-column label="操作" width="180">
          <template slot-scope="props">
              <el-button type="warning" @click="showEditStu(props.row)">编辑</el-button>
              <el-button type="danger" @click="deleteStu(props.row)">删除</el-button>
          </template>
        </el-table-column>
    </el-table>

    <!--
        分页组件
          @size-change： 当改变每页条数时触发的函数
          @current-change：当改变页码时触发的函数
          current-page ：默认的页码
          :page-sizes：每页条数选择框中显示的值
          :page-size : 默认的每页条数
          layout： 分页组件的布局
              total（总条数）, sizes(每页条数), prev（上一页）, pager(所有的页码), next(下一页), jumper（跳转页码）
          :total: 总条数
    -->
    <el-pagination
            @size-change="handleSizeChange"
            @current-change="handleCurrentChange"
            :current-page="pagination.currentPage"
            :page-sizes="[3,5,8]"
            :page-size="pagination.pageSize"
            layout="total, sizes, prev, pager, next, jumper"
            :total="pagination.total">
    </el-pagination>

    <el-dialog title="添加学生信息" :visible.sync="dialogTableVisible4add" @close="resetForm('addForm')">
        <!--
            :model="formData": 关联数据
            :rules: 关联校验规则
            ref： 在获取表单对象时使用
        -->
        <el-form :model="formData" :rules="rules" ref="addForm" label-width="100px" class="demo-ruleForm">
            <el-form-item label="学生学号" prop="number">
                <el-input v-model="formData.number"></el-input>
            </el-form-item>
            <el-form-item label="学生姓名" prop="name">
                <el-input v-model="formData.name"></el-input>
            </el-form-item>
            <el-form-item label="学生生日" prop="birthday">
                <!--v-model : 双向绑定 -->
                <el-input v-model="formData.birthday" type="date"></el-input>
            </el-form-item>
            <el-form-item label="学生地址" prop="address">
                <el-input v-model="formData.address"></el-input>
            </el-form-item>
            <el-form-item align="right">
                <el-button type="primary" @click="addStu()">添加</el-button>
                <el-button @click="resetForm('addForm')">重置</el-button>
            </el-form-item>
        </el-form>
    </el-dialog>

    <el-dialog title="编辑学生信息" :visible.sync="dialogTableVisible4edit" @close="resetForm('editForm')" >
        <!--
            :model="formData": 关联数据
            :rules: 关联校验规则
            ref： 在获取表单对象时使用
        -->
        <el-form :model="editFormData" :rules="rules" ref="editForm" label-width="100px" class="demo-ruleForm">
            <el-form-item label="学生学号" prop="number">
                <el-input v-model="editFormData.number" disabled></el-input>
            </el-form-item>
            <el-form-item label="学生姓名" prop="name">
                <el-input v-model="editFormData.name"></el-input>
            </el-form-item>
            <el-form-item label="学生生日" prop="birthday">
                <!--v-model : 双向绑定 -->
                <el-input v-model="editFormData.birthday" type="date"></el-input>
            </el-form-item>
            <el-form-item label="学生地址" prop="address">
                <el-input v-model="editFormData.address"></el-input>
            </el-form-item>

            <el-form-item align="right">
                <el-button type="warning" @click="updateStu()">修改</el-button>
            </el-form-item>
        </el-form>
    </el-dialog>
</div>
</body>
<script>
    new Vue({
        el:"#div",
        data:{
            dialogTableVisible4add: false,  //添加窗口显示状态
            dialogTableVisible4edit: false, //编辑窗口显示状态
            formData:{},//添加表单的数据
            editFormData: {},//编辑表单的数据
            tableData:[],//表格数据
            pagination: {
                currentPage: 1, //当前页
                pageSize: 5,    //每页显示条数
                total: 0        //总条数
            },
            rules: {
                number: [
                    {required: true, message: '请输入学号', trigger: 'blur'},
                    {min: 2, max: 10, message: '长度在 2 到 10 个字符', trigger: 'blur'}
                ],
                name: [
                    {required: true, message: '请输入姓名', trigger: 'blur'},
                    {min: 2, max: 10, message: '长度在 2 到 10 个字符', trigger: 'blur'}
                ],
                birthday: [
                    {required: true, message: '请选择日期', trigger: 'change'}
                ],
                address: [
                    {required: true, message: '请输入地址', trigger: 'blur'},
                    {min: 2, max: 200, message: '长度在 2 到 200 个字符', trigger: 'blur'}
                ],
            }
        },
        created(){
          this.selectByPage();
        },
        methods:{
            //声明删除学生的方法
            deleteStu(row){  //参数row其实就是改行数据对应的student对象
                //弹出确认框
                this.$confirm('你确定要删除吗？一旦删除数据将不可恢复!', '提示', {
                    confirmButtonText: '确定',
                    cancelButtonText: '取消',
                    type: 'warning'
                }).then(() => {  //用户点击了确定按钮执行该方法
                    //1 发送异步请求
                    //axios.get("studentServlet?method=deleteStudent&number="+row.number)
                    axios.get(`studentServlet?method=deleteStudent&number=${row.number}`).then(resp=>{
                        //2 处理响应结果
                        if(resp.data){  //count=1/0;
                            //重新分页查询
                            this.selectByPage();
                            //提示删除成功!
                            this.$message.success('删除成功!')
                        }
                    })
                }).catch(() => {  //用户点击了取消按钮执行该方法
                    this.$message({
                        type: 'info',
                        message: '我反悔了，不删了...'
                    });
                });
               /* if(confirm("你确定要删除吗？一旦删除数据将不可恢复!")){
                    //1 发送异步请求
                    //axios.get("studentServlet?method=deleteStudent&number="+row.number)
                    axios.get(`studentServlet?method=deleteStudent&number=${row.number}`).then(resp=>{
                        //2 处理响应结果
                        if(resp.data){  //count=1/0;
                            //重新分页查询
                            this.selectByPage();
                        }
                    })
                }*/
            },
            //声明修改学生的方法
            updateStu(){
                //1 准备参数(标记+student信息)
                this.editFormData.method="updateStudent";
                //2 发送异步请求
                axios.get("studentServlet",{params:this.editFormData}).then(resp=>{
                    //3 处理响应结果
                    if(resp.data){  //count=1/0;
                        //3.1 关闭弹出框
                        this.dialogTableVisible4edit = false;
                        //3.2 重新分页查询
                        this.selectByPage();
                    }
                })
            },
            //添加学生信息的方法
            addStu(){
                //1 准备参数(标记+student信息)
                this.formData.method="addStudent";
                //2 发送异步请求
                axios.get("studentServlet",{params:this.formData}).then(resp=>{
                    //3 处理响应结果
                    if(resp.data){  //count=1/0;
                        //3.1 关闭弹出框
                        this.dialogTableVisible4add = false;
                        //3.2 重新分页查询
                        this.selectByPage();
                    }
                });
            },
            //分页查询的方法，方法名必须叫这个
            selectByPage(){
                //向服务器发送请求，获取分页数据
                //可不可以往pagination对象中添加一个method属性，然后一起发送给服务器，可以的
                this.pagination.method="selectByPage";
                //发送请求
                axios.get("studentServlet",{params:this.pagination}).then((resp)=>{
                    //获取响应结果  resp.data--->pageInfo
                    //console.log(resp.data);
                    //展示学生信息，就是将结果中的list数据赋值给tableData
                    this.tableData=resp.data.list;
                    //赋值总条数和每页展示条数
                    this.pagination.total=resp.data.total;
                });
            },
            //改变每页条数时执行的函数
            handleSizeChange(pageSize) {
                //修改分页查询的参数
                this.pagination.pageSize = pageSize;
                //重新执行查询
                this.selectByPage();
            },
            //改变页码时执行的函数
            handleCurrentChange(pageNum) {
                //修改分页查询的参数
                this.pagination.currentPage = pageNum;
                //重新执行查询
                this.selectByPage();
            },
            showAddStu() {
                //弹出窗口
                this.dialogTableVisible4add = true;
            },
            resetForm(addForm) {
                //双向绑定，输入的数据都赋值给了formData， 清空formData数据
                this.formData = {};
                //清除表单的校验数据
                this.$refs[addForm].resetFields();
            },
            showEditStu(row) {
                //1. 弹出窗口
                this.dialogTableVisible4edit = true;
                console.log(row);
                //2. 显示表单数据
                this.editFormData = {
                    number:row.number,
                    name:row.name,
                    birthday:row.birthday,
                    address:row.address,
                }
            }
        }
    });
</script>
</html>